class Solution {
public:
    int longestOnes(vector<int>& nums, int k) {
        int n = nums.size(), cnt = 0, len = 0;

        for(int left = 0, right = 0; right < n; right++)
        {
            // 进窗口
            if(nums[right] == 0)
                cnt++;
            
            while(cnt > k)  // 判断
            {
                if(nums[left] == 0) // 出窗口
                    cnt--;

                left++;
            }

            len = max(len, right - left + 1);   // 更新结果
        }

        return len;
    }
};